//给定一个只包含数字的字符串 s ，用以表示一个 IP 地址，返回所有可能从 s 获得的 有效 IP 地址 。你可以按任何顺序返回答案。 
//
// 有效 IP 地址 正好由四个整数（每个整数位于 0 到 255 之间组成，且不能含有前导 0），整数之间用 '.' 分隔。 
//
// 例如："0.1.2.201" 和 "192.168.1.1" 是 有效 IP 地址，但是 "0.011.255.245"、"192.168.1.312" 
//和 "192.168@1.1" 是 无效 IP 地址。 
//
// 
//
// 示例 1： 
//
// 
//输入：s = "25525511135"
//输出：["255.255.11.135","255.255.111.35"]
// 
//
// 示例 2： 
//
// 
//输入：s = "0000"
//输出：["0.0.0.0"]
// 
//
// 示例 3： 
//
// 
//输入：s = "1111"
//输出：["1.1.1.1"]
// 
//
// 示例 4： 
//
// 
//输入：s = "010010"
//输出：["0.10.0.10","0.100.1.0"]
// 
//
// 示例 5： 
//
// 
//输入：s = "10203040"
//输出：["10.20.30.40","102.0.30.40","10.203.0.40"]
// 
//
// 
//
// 提示： 
//
// 
// 0 <= s.length <= 3000 
// s 仅由数字组成 
// 
//
// 
//
// 
// 注意：本题与主站 93 题相同：https://leetcode-cn.com/problems/restore-ip-addresses/ 
//
// Related Topics 字符串 回溯 👍 34 👎 0

package leetcode.editor.cn;

import java.util.ArrayList;
import java.util.List;

//leetcode submit region begin(Prohibit modification and deletion)
class SolutionOffer2_087 {
    List<String> result = new ArrayList<>();
    List<String> path = new ArrayList<>();
    public List<String> restoreIpAddresses(String s) {
        traversal(s, 0);
        return result;
    }

    public void traversal(String s, int startIndex){
        if(path.size() > 4) return;
        if(path.size() == 4){
            if(startIndex == s.length()){
                String join = String.join(".", path);
                result.add(join);
            }
            return;
        }
        for(int i = startIndex; i < s.length(); i++){
            String subStr = s.substring(startIndex, i+1);
            if(check(subStr)){
                path.add(subStr);
                traversal(s, i+1);
                path.remove(path.size()-1);
            }
        }
    }

    private boolean check(String subStr) {
        if(subStr.length() > 3){
            return false;
        }
        if(subStr.charAt(0) == '0' && subStr.length() > 1){
            return false;
        }
        for(int i = 0; i < subStr.length(); i++){
            if(subStr.charAt(i) < '0' || subStr.charAt(i) > '9'){
                return false;
            }
            if(Integer.parseInt(subStr) > 255) {
                return false;
            }
        }
        return true;
    }

    public static void main(String[] args) {
        new SolutionOffer2_087().restoreIpAddresses("25525511135");
    }
}
//leetcode submit region end(Prohibit modification and deletion)
